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(54) Enhanced L1/L2 code channel for global positioning system receivers. 

@ An enhanced P-code channel (60) for use in a 
GPS receiver (10) to simultaneously track L1 
and L2 comprises a P-code clock generator (62) 
for generating two code clocks. The first code 
clock associates with L1 and the second as- 
sociates with L2. The code clocks have the 
same frequency but different phases from one 
another. Circuitry (64) and (66) generate and 
store a plurality of P-code chips. A first circuit 
(68, 70) selects and updates P-code chips from 
the stored P-code chips that are in phase with 
the L1 code clock. A second circuit (72 and 74) 
selects and updates P-code chips from the 
P-code chips and phased with the L2 code 
clock. 
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TECHNICAL FIELD OF THE INVENTION 

This invention relates to Global Positioning Sys- 
tem (GPS) receivers and more particularly a method 
for enhancing an a single receiver channel for proc- s 
essing a plurality of L-band signals. 

BACKGROUND OF THE INVENTION 

The NAVSTAR Global Positioning System (GPS) 10 
is used to determine exact geographic position (i.e. 
latitude, longitude, and height above the earth) as well 
as the exact velocity and time of stationary or moving 
objects. The navigation receiver calculates position, 
and time by determining distance to a series of satel- 1 5 
lites. The navigation receiver calculates velocity by 
determining doppler frequency shift of the satellite 
signals. 

The NAVSTAR GPS receiver must receive sig- 
nals generated from the satellite about 11,000 miles 20 
away. Each GPS satellite transmits a 6-watt signal. 
The satellite and receiver, therefore, employs spread 
spectrum techniques to differentiate the signal from 
the noise. This is essential since at the antenna the 
GPS signal is typically about 20 dB below ambient 25 
cosmic noise. "Spread spectrum" means that the fre- 
quency or instantaneous phase of the signal being 
transmitted changes as a function of time. Using 
spread spectrum signal processing techniques, the 
receiver can track the spread spectrum signal coming 30 
from the satellite by estimating a duplicate image of 
the signal. A precise match of the satellite's spread 
spectrum signal produces a potential signal process- 
ing gain of up to 53 decibels. 

Each satellite generates two spread spectrum 35 
signals centered around separate frequencies. The 
L1 channel is centered about 1575.42 MHz, and has 
course/acquisition-(C/A-) code and precision- (P-) 
code modulated on it C/A-code has a 1.023 MHz 
chipping rate with a band width of about 2 MHz, and 40 
P-code has a 10.23 MHz chipping rate with a band- 
width of about 20 MHz. The L2 channel is centered 
around 1227.6 MHz and only has P-code modulated 
on it. 

For some applications it is desirable to track both 45 
L1 and L2. A position can be derived from just the C/A- 
code or P-code on the L1 band. However, there is 
ionospheric delay that unpredictably affects the per- 
ceived range to the satellite from the receiver. These 
errors can be corrected by tracking both L1 and L2 so 
and by measuring the difference in the range that is 
perceived by the receiver on these L-bands. In this 
manner, the ionospheric errors can be reduced and 
the navigation solution can be made more accurate by 
a few meters. In addition, tracking both L bands simul- 55 
taneously provides more anti-jamming immunity for 
operation in hostile environments. 

The easiest way to track L1 and L2 is with an in- 
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dependent tracking loop for each channel. In all imple- 
mentations to date, either a single channel is multi- 
plexed between L1 and L2 to reduce hardware re- 
quirements or an additional complete hardware chan- 
nel is provided. This either compromises performance 
and increases software complexity or increases hard- 
ware. In either case, this capability adds significant 
cost to the receiver. 

For some operational scenarios, it may also be 
desirable to be able to switch between having two in- 
dependent tracking loops and having one tracking 
loop with a phase delta between L1 and L2. Two in- 
dependent loops will be used in hostile environments 
where there is a good possibility of losing either L1 or 
L2. 

As an example of the problem, consider the situa- 
tion of navigating above 80° latitude north. Above 80° 
latitude, the Northern Lights and sun spot activity in 
the north pole make the ionosphere so active that 
there is the need for frequent L1 and L2 calculations 
to maintain GPS system accuracy. Using present sys- 
tems, performing these frequent L1 and L2 calcula- 
tions makes it is necessary to add additional hardware 
channels to the receiver. This increases space and 
cost for each receiver, and increases processor 
throughput and software complexity. Computer re- 
sources to support the increased number of hardware 
channels forces the user to make some performance 
compromises. If a system existed that can track L1 
and L2 without the penalty of additional hardware, in- 
creased computer throughput and increased software 
complexity it would have value for the GPS user com- 
munity. 

In known systems, it has been necessary to use 
two channels to track both L1 and L2. The same P-co- 
de information is transmitted on the L1 and L2 bands. 
However, the receiver sees a phase shift between the 
two signals because of ionospheric delay. The 
amount of delay is a function of the level of the iono- 
spheric influence. Therefore, if it were possible to use 
the fact that this information is related, then it may not 
be necessary to use two wholly independent channels 
for tracking L1 and L2. 

Accordingly, a need exists in the art for a system 
and method of tracking both L1 and L2 in a GPS re- 
ceiver without resorting to two distinct hardware chan- 
nel receivers or time sharing a single channel. 

A further need exists in the art for such a receiver 
designed in a way so as to minimize power consump- 
tion and size. 

A further need exists in the art for method and 
system of providing a GPS receiver which allows for 
both single and double looped processing of L1 and 
L2 interchangeably. This allows for selecting between 
the high jamming immunity of tracking L1 and L2 in- 
dependently or the processor throughput savings of 
tracking L1 and L2 together. 
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SUMMARY OF THE INVENTION 

Accordingly, the present invention provides in- 
ventive subject matter which overcomes the problems 
associated with ionospheric delay in Global Position- s 
ing System (GPS) receivers. In particular, the present 
invention provides a single enhanced precision code 
(P-code) channel for use in a GPS receiver that can 
simultaneously track L1 and 12 from a single satellite. 

The enhanced P-code channel includes a single 10 
P-code clock generator for generating two code clock 
signals (L1 and L2) with the same frequency but a dif- 
ferent phase. A P-code generator uses one of the P- 
code docks to generate a continuous P-code data 
stream. Circuitry then stores a plurality of the most re- 15 
cently generated P-code chips. A counter and multi- 
plexer circuit is then used to maintain a constant P-co- 
de stream (which may be delayed from the output of 
the P-code generator) by using one of the P-code 
clocks. In addition, carrier generation and mixing cir- 20 
cuitry, code delay shift registers and mixing circuitry, 
and multiple pre-detection accumulators exist to allow 
for the simultaneous tracking of L1 and L2 signals. 

A technical advantage of the present system is 
that, by enhancing a single P-code channel, it is pos- 25 
sible to obtain the benefit of independent L1 and L2 
tracking loops within a GPS system without the pen- 
alty of having two independent hardware channels for 
this purpose. 

Another technical advantage of the present in- 30 
vention is that it is possible to gain the benefit of track- 
ing L2 in addition to L1 to reduce error introduced by 
ionospheric delay, without the additional processor 
throughput requirements of tracking L2 independent- 
ly. 35 

Yet another technical advantage of the present 
invention is that it permits making continual L1 and L2 
calculations without the need for additional computing 
and support equipment. 

40 

BRIEF DESCRIPTION OF THE DRAWINGS 

A more complete understanding of the present in- 
vention may be acquired by referring to the detailed 
description and claims when considered in connec- 45 
tion with the accompanying drawings in which like ref- 
erence numerals indicate like features wherein: 
FIGURE 1 is a block diagram of a GPS receiver 
that may use the enhanced L1/L2 channel of the 
present invention; 50 
FIGURE 2 is a block diagram of a typical C/A- and 
P-code channel for use in a GPS receiver for re- 
ceiving L1 and L2. 

FIGURE 3 is a block diagram of a preferred em- 
bodiment of the enhanced P-code channel for 55 
tracking L1 and L2 for GPS applications; 
FIGURE 4 is a block diagram representing the P- 
code clock generator according to a preferred 



embodiment of the present invention; 
FIGURE 5 provides a comparison chart between 
a typical and enhanced P-code channel for track- 
ing L1 and L2 of the present invention. 
Figure 6 shows a block diagram of PCOAC 1 01 0. 
Unused functions can be turned off allowing for a 
high level of power conservation in applications 
where power usage and/or heat dissipation is an 
important consideration. 

Figure 7 is a block diagram of the top level mod- 
ules which electrically make up channel A(1 1) of 
PCOAC 10: Base Band Module 1130 generates 
several global clocks for system synchronization; 

DETAILED DESCRIPTION OF THE INVENTION 

The preferred embodiment of the present inven- 
tion is best understood by referring to the FIGURES 
wherein like numbers are used for like corresponding 
parts of the various components. 

To understand the present invention, it is best to 
understand the environment of the preferred embodi- 
ment. For this purpose, FIGURE 1 provides a simple 
block diagram of a Global Positioning System (GPS) 
navigation receiver. The system of FIGURE 1 is de- 
scribed in more detail in U.S. Patent Application Serial 
No. (Tl Docket No TI-1 5358) to John P. Volpi et al and 
assigned to Texas Instruments Incorporated entitled 
"System and Method for Digital Navigation Satellite 
Receiver" and U.S. Patent Application Serial No. (Tl 
Docket No. TI-1 5357) to Leonard LaPadula III, et al, 
also assigned to Texas Instruments Incorporated, en- 
titled "Method and System for Multi-Channel and 
Search Global Position System Signal Processor" 
both filed on February 28, 1991. U.S. Patent Applica- 
tion Serial Nos. and 

are hereby expressly incorporated by refer- 
ence in their entirety. 

FIGURE 1 is a simple block diagram of the whole 
receiver. A single RF path amplifies and down- 
converts the L1 or L2 signal to an intermediate fre- 
quency (IF), The receiver performs analog-to-digital 
conversion before any GPS signal processing takes 
place. After the signal is digitized, the signal is proc- 
essed in three signal processing chips (SPC). The 
SPCs perform ail the GPS hardware signal process- 
ing. 

Referring more particularly to FIGURE 1, there is 
shown receiver 10 which utilizes antenna 12 feeding 
into preamp assembly 14. Antenna preamp assembly 
14 feeds into L1/L2 frequency selector 16 which 
sends signals to L-band down conversion 18. These 
components all operate under the control of reference 
oscillator 20 and frequency synthesizer 22. Refer- 
ence oscillator 20 and frequency synthesizer 22 pro- 
vide oscillation for L-band down conversion 18. Out- 
put from L-band down conversion 18 is a second IF 
that goes into an analog-to-digital converter (A/D) 
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with automatic gain control (AGC) circuit 24. The out- 
put of this AID circuit is then channelized to code and 
carrier wipe off in circuits 26, 28 and 30. This is where 
the remote signal transmitted by the GPS satellite is 
compared and matched with the receiver's estimate of s 
the remote signal. 

The outputs of signal processing circuits, 26, 28 
and 30 are shown as signals 32 into processor com- 
puter 34. Processor computer 34 provides signals 36 
to signal processing circuit 26, 28 and 30 to direct the 10 
circuits to change their code and carrier estimates, as 
well as for general control of the circuits. 

Each signal processing circuit 26, 28 and 30, 
uniquely and completely generates carrier estimates, 
code estimates, base band pre-detection estimates is 
and contains all the correlators for signal processing 
as well as provides autonomous signal search capa- 
bility for two satellites. Each channel also has the ca- 
pability to simultaneously track both the C/A-code and 
P-code. whereever used herein the term P-code shall 20 
include P(Y>code. 

FIGURE 2 shows how a typical method to perform 
pre-detection integration in single C/A- and P-code 
channel 37. This channel 20 can only track L1 C/A- 
and P-code or L2 P-code. Carrier generator 36 gen- 25 
erates a complex estimate of the incoming GPS car- 
rier. Carrier mixer 38 wipes off the incoming carrier. P- 
code clock generator 40 and P-code generator 42 
generate an estimate of P-code and C/A- code clock 
generator 44 and C/A-code generator 46 generate an 30 
estimate of the C/A-code. P-code delay shift register 
48 and C/A-code delay shift register 50 generate a 
plurality of P-code and C/A-code phases 1/2-chip 
apart, respectively. Finally, code is wiped off in P-co- 
de mixers 52 and C/A-code mixers 54. Pre-detection 35 
integration is then performed using an integrate circuit 
56. 

Six correlators are shown so the P-code and C/A- 
code can be track simultaneously (three for P-code 
and three for C/A-code). In addition, it is possible to 40 
dedicate all six correlators to C/A-code using correla- 
tor switches 58 for search modes of operation. This is 
done so that C/A-code can be found more quickly in 
typical search operations. 

For some applications of GPS, it is desirable to be 45 
able to track L1 and L2 simultaneously. Hardware 
aside, the easiest way to do this is with an indepen- 
dent tracking loop for L1 and 12. By enhancing the 
previously described channel 37, it is possible to get 
the benefit of independent L1 and L2 tracking without so 
the penalty of having two independent channels. For 
some operational scenarios, it also may be desirable 
to be able to switch between having two independent 
tracking loops and having one tracking loop with a 
phase delta between L1 and L2. Two independent 55 
loops would be used in hostile environments where 
there is a good possibility of losing either L1 or 12. 
One tracking loop may be desirable for less processor 



throughout when there is no threat of losing the main 
L-band. Within a P-code receiver such as that of FIG- 
URE 1, the present invention allows this operational 
flexibility. For these purposes, FIGURE 3 describes 
an enhanced single P-code L1/L2 channel that may 
be used to enhance the capability of signal processing 
circuits 26, 28 and 30. 

FIGURE 3 shows an enhanced L1/L2 channel 60 
according to the present invention. The modified P- 
code clock generator 62 generates two P-code clocks 
with same frequency and independent phase, one for 
L1 and one for L2. The modified P-code dock gener- 
ator 62 also detects which of these clock lead. The 
leading clock is used to clock P-code generator 64. 
Each new P-code chip is stored in the next location of 
the P-code circular buffer 302. P-code clock genera- 
tor 62 is used to increment the L1 and L2 P-code chip 
counters 68 and 70, respectively. Whenever the L1 P- 
code chip counter, 68, is incremented, 16-to-1 MUX 
70 passes the next P-code chip stored in the P-code 
circular buffer 66 to the L1 P-code delay shift register 
76. The L2 P-code chip counter 72 and 16-to-1 MUX 
74 are implemented and work in exactly the same 
manner as the L1 P-code chip counter 68 and 16-to- 
1 MUX, 70. Thus, from one P-code generator 64 two 
P-code outputs, one for L1 and one for L2, go to code 
delay shift registers, 76 and 78, respectively. This rep- 
resents a considerable savings in circuitry because P- 
code generator 64 comprises numerous gates and 
additionally requires significant computer processing 
capability to support its operation. Although the pre- 
ferred embodiment requires a separate carrier gener- 
ator for each signal frequency, carrier generators for 
L1 and L2 are easy to build and do not consume near- 
ly as much power as would a second complete chan- 
nel. 

The enhanced L1/L2 channel 60 of FIGURE 3 
provides maximum operational flexibility with minimal 
additional circuitry. Circuits which are not changed 
from the previously described typical C/A- and P-code 
channel include the P-code generator 64, C/A-code 
clock generator 44, and C/A-code generator 46. The 
carrier generators, 80 and 82, and carrier mixers, 84 
and 86 are the same as the previously shown carrier 
generator 36 and carrier mixer 38, except that L1 car- 
rier generator 80 is always configured to generate an 
L1 carrier and the L2 carrier generator 82 is always 
configured to generate an L2 carrier. Also, the code 
delay shift registers, 76,78 and 88, code mixers, 90, 
92 and 94, the pre-detection integration circuitry 96, 
and correlator switches 98 and 100 are implemented 
and function such as the code delay shift registers 48 
and 50, coder mixers, 52 and 54, the pre-detection in- 
tegration circuitry 56 and the correlator switches 58 
shown in the typical C/A- and P-code channel 37 of 
FIGURE 2. The only difference being that there is an 
extra set of P-code delay shift registers 78, P-code 
mixers 92 and correlator switches 100 and that the 
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pre-detection integration circuitry 332 supports three 
additional correlators. This is done to accommodate 
the extra three correlators required to track L2 P-co- 
de. 

Unique to the enhanced channel is a modified P- 5 
code clock generator 62, a P-code circular buffer 66, 
two P-code chip counters, 68 and 72, and two 16-to- 
1 multiplexers (MUX), 70 and 74. 

FIGURE 4 shows a high level block diagram of 
the modified P-code clock generator 62. This circuit is 10 
a unique modification of the low-powered digital oscil- 
lator detailed in co-pending application entitled "Meth- 
od and Systems for a Multi-Channel Global Position 
System Signal Processor". Circuitry to determine 
which clock leads is not shown. One approach to de- 15 
term in e the leading clock is to extend the P-code chip 
counters 68 and 74 an extra two bits and compare the 
counter values to see which clock leads. 

The circuit operation of the modified P-code clock 
generator 62, is basically the same as the code clock 20 
generator described in the previously mentioned co- 
pending U.S. Patent Applications. The modification is 
that there are two separate 16- bit P-code clock phase 
words 1 12 and 1 14, one for determining the phase of 
the L1 P-code clock and the other for determining the 25 
phase of the L2 P-code clock. Since initial P-code 
clock phase only affects the 13 most significant bits of 
the 32-bit P-code clock generator adder/accumulator, 
the 19 least significant bits of the adder/accumulator 
122 are common to both the L1 and the L2 P-code 30 
clock. The frequency word 1 1 6 is also common to both 
the L1 and L2 P-code clock. Along with the two sep- 
arate P-code clock phase words, 112 and 1 14 are two 
13- bit adder/accumulators 118 and 120 one for L1 P- 
code clock and one for L2 P-code clock, which togeth- 35 
er with the 19-bit adder/accumulator 122 make up two 
separate 32-bit adder/accumulators capable of gen- 
erating carriers to the two state machines 1 24 and 1 26 
with the same frequency but different phase. The 
state machine and carry delay circuits 124 and 126 40 
are exactly the same as described in the previously 
mentioned co-pending U.S. Patent Applications. 

FIGURE 5 shows the estimated difference be- 
tween a typical single L-band channel and the en- 
hanced L1 /L2 channel of the present invention. An en- 45 
hanced channel requires only 42% additional circuitry 
over a normal channel and provides the performance 
benefit and software reduction of two completely inde- 
pendent channels for tracking L1 and L2 simultane- 
ously. 50 

The cost of the enhanced channel is considerably 
less than the 42% when overhead circuitry such as 
channel timing and control, processor interface and 
search specific circuits are included in the gate count 
estimates. Also note that for this specific example, 55 
that the enhanced channel has three additional corre- 
lators. This provides approximately a 50% improve- 
ment in search speed. As a result of the enhanced P- 



code channel of the present invention, there is provid- 
ed an apparatus and method for significantly increas- 
ing GPS system receiver channel flexibility without a 
significant increase in circuitry or software complexi- 
ty. 

Although this description describes the invention 
with reference to the above specific embodiments, the 
claims, and not this description, limit the scope of the 
invention. Various modifications or the disclosed em- 
bodiment, as well as alternative embodiments of the 
invention, will become apparent to persons skilled in 
the art upon reference to the above description. 
Therefore, the appended claims will cover such mod- 
ification that follow up in the true scope of the inven- 
tion. 

Aspects of the present invention will be further ap- 
preciated from the following: 

The P-Code Channel on-a-chip (PCOAC) to be 
described is a dual channel GPS signal processor in- 
tegrated circuit. A 95-pin ceramic pin-grid-array 
(PGA) contains the 348,300 transistor CMOS gate ar- 
ray. Major features include: two independent GPS 
channels; a search processor for improved acquisi- 
tion time; an embedded Y-code generator; system 
synchronization control; and a 16-bit processor inter- 
face. 

Figure 16 shows a block diagram of PCOAC 
1010. Unused functions can be turned off allowing for 
a high level of power conservation in applications 
where power usage and/or heat dissipation is an im- 
portant consideration. 

Each channel of circuit 1010 is a dedicated signal 
processing circuit which de-modulates the code and 
carrier of a GPS signal and performs pre-detection in- 
tegration. Each channel contains a code clock gener- 
ator 1103 (1104), a P and C/A-code generator 1105 
(1 1 06), an L1/L2 carrier generator 1 109 (1 1 10), eight 
correlators 1111, 1113, 1115, 1117 (1112, 1114, 
1116, 11 18) and a noise meter 11 19 (11 20). Each of 
the eight correlators can be selected to operate with 
C/A-code or P-Code. A Y-code generator 1 108 com- 
mon to both channels provides independent Y-code 
for both channels. 

Search processor 1123 and discrete fourier 
transform (DFT) function 1124 improve signal acqui- 
sition capability. The DFT separates the sample inte- 
gration data into seven frequency bins. Search proc- 
essor 1123 interpolates between these seven fre- 
quency bins to obtain six additional frequency bins, 
producing a total of thirteen frequency bins per corre- 
lator. The search processor implements a Tong de- 
tection algorithm on all eight correlators for each of 
the thirteen frequency bins resulting in the simultane- 
ous search of 1 104 search bins per channel. 

PCOAC 1010 supports three frequency plans, 
57.7920 MHz, 40.9216 MHz and 40.9200 MHz oper- 
ation. Several programmable clocks/interrupts 1130 
are provided to synchronize the host processor to 
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PCOAC operation. Various interrupt schemes are de- 
signed to allow trade-offs to be made between system 
performance, processor throughput requirements and 
the complexity of the software. 

A standard 16-bit processor interface 1131 is util- 
ized. In order to minimize read/write overhead to the 
PCOAC, integration samples are buffered 1121 
(1 1 22) and the memory map is designed so that block 
moves are ail that is required for channel updates dur- 
ing normal tracking operations. 

Figure 7 is a block diagram of the top level mod- 
ules which electrically make up channel A(11) of 
PCOAC 1 0: Base Band Module 1 1 30 generates sev- 
eral global clocks for system synchronization; 

Channel Timing Module 1101 generates all 
clocks and synchronization pulses specific to a single 
channel; 

Code Generator Module 21 includes a program- 
mable code clock generator, P-code and C/A-code 
generators/setters, and P-code and C/A-code state 
advance and retard for search; 

Y-Code Generator Module 1108 converts the P- 
code into Y-code for both channels simultaneously 
even during code state advances; 

Front-End Correlator Module 1201 provides L1 or 
L2 carrier generation, a carrier mixer, a P-code and 
C/A-code delay shift register (to generate eight code 
phases), code mixers, data wipe-off, and noise meter 
signal selection; 

Intermediate Correlator Module 1202 performs 
the first stage of sample integration for eight complex 
correlators and a noise meter; 

Black-End Correlator Module 1203 performs the 
final stage of sample integration, and also performs 
noise measurement for aiding in search and tracking 
(one per channel); 

IRAM 1204 and Q RAM 1205 are two 64 x 1 6-bit 
3-port RAMs per channel for sample integration buf- 
fering or to hold intermediate values for DFT calcula- 
tions; 

Discrete Fourier Transfer (DFT) Module 1124 
converts integration samples from all correlators of 
both channels into seven frequency bins of sample 
data for search operations; 

Search Processor Module 1206 interpolates six 
additional frequency bins from those provided by the 
DFT module, performs Tong detection on all thirteen 
frequency bins of data and retards the code state until 
a signal is found; 

Search Processor RAM 1207 is a 64 x 16- bit 3- 
port RAM used by the search processor as a holding 
register for active Tong counts during search or noise 
measurement buffering during tracking; 

Processor Interface Module 1131 provides ad- 
dress decode to generate internal read and write 
strobes, integration sample buffering control, a pro- 
grammable ring oscillator tor test and other miscella- 
neous functions. 



Digital signal processing circuitry as exemplified 
herein may be implemented by means of a single in- 
tegrated circuit 

5 

Claims 

1 . An en hanced P-code chan nel for use in a GPS re- 
ceiver, said channel being adapted for simultane- 

10 ously tracking L1 and L2 and comprising: 

a P-code clock generator for generating two code 
clocks, the first docks associated with L1 and the 
second of said code clocks associated with L2, 
said code clocks having the same frequency but 

15 different phase from one another; 

circuitry for generating a plurality of P-code chips 
and storing a plurality of the most recently gener- 
ated of said P-code chips; 
a first circuit for selecting and update P-code 

20 chips from said stored plurality of P-code chips 
said selected and updated chips being in phase 
with said L-1 code clock; 
a second circuit for selecting and updating P-co- 
de chips from said stored plurality of P-code chips 

25 said selected and updated chips being in phase 
with said L-2 code clock. 

2. A multi-channel GPS signal processor for use in 
a GPS receiver, said processor comprising: 

30 digital signal processing circuitry on a single inte- 
grated circuit for acquiring and tracking valid P- 
code signals from at least one satellite of said 
GPS system; and 

an enhanced P-code channel as claimed in claim 
35 1. 

3. A receiver for determining geographical position, 
velocity, and time from analog signal information 
received from a plurality of navigational satellites, 

40 said signal information having data shifts depend- 
ent upon distance and frequency shifts depend- 
ent upon the relevant velocity between the satel- 
lite's transmission position and the geographical 
position of said receiver, wherein said analog sig- 

45 nal is significantly weaker than ambient atmos- 
pheric noise, said receiver comprising: 
a digital signal processing circuit for acquiring 
said signal in the presence of said noise, for es- 
timating the current position and for correcting 

so said estimate based upon data exchanged be- 
tween said digital signal processing circuit and 
said processor 

an enhanced P-code channel associated within 
said digital processing circuit for use in said re- 
55 ceiver, said channel capable of simultaneously 
tracking L1 and L2 and comprising: 
a single P-code clock generator for generating 
two code clocks, a first of said code clocks asso- 
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ciated with L1 and a second of said code clocks 
associated with L2, said code docks having the 
same frequency but different phase from each 
other; 

circuitry for generating a plurality of P-co- 
de chips and storing a plurality of said P-code 
chips, said P-code chips being those most recent- 
ly generated by said digital signal processing cir- 
cuit; 

a first circuit for selecting and updating P- 
code chips from said plurality of chips, said chips 
being in phase with said L1 code clock; and 

a second circuit for selecting and updating 
P-code chips from said stored plurality of chips, 
said chips being in phase with said L2 code dock. 

4. The apparatus of any of Claims 1 -3, further com- 
prising a P-code circular buffer within said gener- 
ating and storing circuitry for generating two 
phases of P-code for tracking L1 and L2. 

5. The apparatus of Claim 4, wherein said channel 
is associated to independently track L1 or L2. 

6. The apparatus of any of Claims 1 -3, further com- 
prising circuitry for simultaneously generating 
C/A-code for L1 f P-code for L1, and P-code for 
L2. 

7. The apparatus of Claim 6, further comprising cir- 
cuitry for vector summing said C/A-code for L1 , P- 
code for L1, and P-code for L2, thereby increas- 
ing sensitivity of said channel. 

8. The apparatus of any of Claim 1-3, further com- 
prising circuitry for continuous ionospheric cor- 
rection within said channel. 

9. A method for simultaneously tracking L1 and 12 
in a single P-code channel for use in the GPS re- 
ceiver, said method comprising the steps of: 

generating two code docks using a single 
P-code clock generator, the first of said code 
docks being associated with L1 and the second 
of said code docks being associated with L2, said 
code docks further having the same frequency 
but different phases; 

generating a plurality of P-code chips; 

storing a plurality of the most recently gen- 
erated of said P-code chips; 

selecting and updating P-code chip ad- 
dresses from said stored plurality of P-code chips 
in phase with said L1 code dock; and 

selecting and updating P-code chips from 
said stored plurality of chips in phase with said 12 
code dock. 

10. The method of Claim 9, further comprising the 



step of tracking L1 in said channel for assisting L2 
tracking. 

11. The method of Claim 9, further comprising the 
5 step of tracking L2 in said channel to a tracking 

ofL1. 

12. A method for determining geographical position, 
velocity, and time from analog signal information 

10 received from a plurality of navigational satellites, 
said signal information having data shifts depend- 
ing upon distance and frequency shifts depended 
upon the relative velocity between the satellite's 
transmission position and the geographical posi- 
ts tion of said receiver, wherein said analog signal 
is significantly weaker than ambient atmospheric 
noise, said method comprising the steps of: 

acquiring said signal in the presence of 
said noise, estimating the current position, and 
20 correcting said estimate; and 

simultaneously tracking L1 and L2 in a sin- 
gle enhanced P-code channel said tracking step 
comprising the steps of: 

generating two code docks using a 
25 single P-code dock generator the first of said 
code clocks being associated with L1 and the 
second of said code clocks associated with L2, 
said code docks further having the same frequen- 
cy but different phases; 
30 generating a plurality of P-code 

chips; 

storing a plurality of the most re- 
cently generated of said P-code chips; 

selecting and updating P-code chip 
35 addresses from said stored plurality of P-code 
chips in phase with said L1 code dock; and 

selecting and updating P-code 
chips from said stored plurality of chips in phase 
with said L2 code dock. 

40 

13. The method of Claim 12, further comprising the 
step of generating two phases of P-code for track- 
ing L1 and L2 separately. 

45 14. The method of either of Claims 9 or 12, further 
comprising the step of independently tracking L1 
orL2. 

1 5. The method of either Claims 9 or 12, further com- 
50 prising the step of simultaneously generating 

C/A-code for L1 , P-code for L1 , and P-code within 
said single enhanced channel. 

16. The method of Claim 15, further comprising the 
55 step of vector summing said C/A-code for L1 , P- 

code for L1 and P-code for L2. 

17. The method of either of Claims 9 or 12, further 
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comprising the step of continuously performing 
ionospheric correction within said channel. 
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